import request from './request'
// 判断请求接口的用户端 1为酒店端 2为保洁端
let type = ''
// 全局配置的请求域名
let baseUrl = 'https://www.zhuoxianrenli.cn'
// let baseUrl = 'http://kfs.chinacxy.net'
let header = {
	'content-type': 'application/json;charset=UTF-8'
}
//可以new多个request来支持多个域名请求
let $http = new request({
	//接口请求地址
	baseUrl: baseUrl,
	//服务器本地上传文件地址
	fileUrl: baseUrl,
	// 服务器上传图片默认url
	// defaultUploadUrl: "api/common/v1/upload_image",
	//设置请求头（如果使用报错跨域问题，可能是content-type请求类型和后台那边设置的不一致）
	header: header,
	// 请求超时时间（默认6000）
	timeout: 6000,
	// 默认配置（可不写）
	config: {
		// 是否自动提示错误
		isPrompt: true,
		// 是否显示加载动画
		load: true,
		// 是否使用数据工厂
		isFactory: true
	}
})

// 添加获取七牛云token的方法
$http.getQnToken = function(callback) {
	//该地址需要开发者自行配置（每个后台的接口风格都不一样）
	$http.get('api/kemean/aid/qn_upload').then(data => {
		/*
		 *接口返回参数：
		 *visitPrefix:访问文件的域名
		 *token:七牛云上传token
		 *folderPath:上传的文件夹
		 *region: 地区 默认为：SCN
		 */
		callback({
			visitPrefix: data.visitPrefix,
			token: data.token,
			folderPath: data.folderPath,
			region: 'SCN'
		})
	})
}

//当前接口请求数
let requestNum = 0
//请求开始拦截器
$http.requestStart = function(options) {
	if (options.load) {
		if (requestNum <= 0) {
			// 打开加载动画
			// uni.showLoading({
			// 	title: '加载中',
			// 	mask: true
			// })
		}
		requestNum += 1
	}
	// 图片上传大小限制
	if (options.method == 'FILE' && options.maxSize) {
		// 文件最大字节: options.maxSize 可以在调用方法的时候加入参数
		const maxSize = options.maxSize
		for (let item of options.files) {
			if (item.size > maxSize) {
				setTimeout(() => {
					uni.showToast({
						title: '图片过大，请重新上传',
						icon: 'none'
					})
				}, 500)
				return false
			}
		}
	}
	if (options.method == 'GET' || options.method == 'get') {
		return options
	} else {
		type = getApp().globalData.type
		if (type == 1) {
			//请求前加入token
			options.header['token'] = uni.getStorageSync('hotelData').token || ''
		} else if (type == 2) {
			//请求前加入token
			options.header['token'] = uni.getStorageSync('cleaningData').token || ''
		} else {
			uni.showToast({
				title: "登录失效！请重新登录",
				icon: "none"
			})
			setTimeout(() => {
				getApp().globalData.type = ''
				uni.reLaunch({
					url: '/pages/index/index'
				})
				return false
			}, 1500)
		}
	}

	return options // return false 表示请求拦截，不会继续请求
}
//请求结束
$http.requestEnd = function(options) {
	//判断当前接口是否需要加载动画
	if (options.load) {
		requestNum = requestNum - 1
		if (requestNum <= 0) {
			// uni.hideLoading()
		}
	}
}
//登录弹窗次数
let loginPopupNum = 0
//所有接口数据处理（可在接口里设置不调用此方法）
//此方法需要开发者根据各自的接口返回类型修改，以下只是模板
$http.dataFactory = async function(res) {
	// console.log('接口请求数据', {
	// 	url: res.url,
	// 	resolve: res.response,
	// 	header: res.header,
	// 	data: res.data,
	// 	method: res.method,
	// })

	if (res.response.statusCode && res.response.statusCode == 200) {
		let httpData = res.response.data
		// console.log('返回的数据',res.response.data)
		// console.log('返回的数据类型是否为字符串',typeof (httpData) === 'string')
		if (typeof(httpData) === 'string') {
			httpData = JSON.parse(httpData)
		}
		/*********以下只是模板(及共参考)，需要开发者根据各自的接口返回类型修改*********/

		//判断数据是否请求成功
		if (httpData.success || httpData.code == 200) {
			// 返回正确的结果(then接受数据或await 接收的数据)
			return Promise.resolve(httpData.data)
		} else if (httpData.code == 101 || httpData.code == 102) {
			uni.clearStorageSync();
			// 返回错误的结果(catch接受数据)
			// return Promise.reject({
			// 	statusCode: 1001,
			// 	// errMsg: '【request】' + (httpData.info || httpData.msg)
			// 	// errMsg: '登录失效！请重新登录！'
			// })
		} else if (httpData.code == 100) {
			return Promise.reject({
				statusCode: 1003,
				errMsg: httpData.info || httpData.msg
			})
		} else if (httpData.code == 104) {
			return Promise.reject({
				statusCode: 1004,
				// errMsg: '【request】' + (httpData.info || httpData.msg)
				errMsg: '未绑定手机号！请先绑定手机号'
			})
		} else {
			// 其他错误提示
			// 返回错误的结果(catch接受数据)
			return Promise.reject({
				statusCode: 1002,
				// errMsg: '【request】' + (httpData.info || httpData.msg)
				errMsg: httpData.info || httpData.msg
			})
		}

		/*********以上只是模板(及共参考)，需要开发者根据各自的接口返回类型修改*********/

	} else {

		// 返回错误的结果(catch接受数据)
		return Promise.reject({
			statusCode: res.response.statusCode,
			// errMsg: '【request】数据工厂验证不通过'
			errMsg: '请求失败'
		})
	}
}
// 错误回调
$http.requestError = function(e) {
	console.log("错误信息 =>", e)
	// e.statusCode === 0 是参数效验错误抛出的
	if (e.statusCode === 0) {
		throw e
	} else if (e.statusCode == 1001) {
		if (type == 1) {
			uni.clearStorageSync();
			setTimeout(() => {
				uni.switchTab({
					url: '/pages/tag/my/my'
				})
			}, 1500)
		} else if (type == 2) {
			uni.removeStorageSync('cleaningData');
			setTimeout(() => {
				uni.redirectTo({
				    url: '/pages/index/index'
				});

			}, 1500)
			// uni.navigateTo({
			// 	url: '/cleaningAdmin/home/home'
			// });
		}

	} else if (e.statusCode == 1003 || e.statusCode == 1004) {
		return
	} else {
		console.log('提示信息')
		uni.showToast({
			title: e.errMsg,
			icon: 'none'
		})
	}
}
export default $http
